Docket: CR9-98-095 


<=> w IN THE UNITED STATES PATENT AND TRADEMARK OFFICE 

^vo c Patent Application Transmittal ft m 


vo Ss^i s t an t Commissioner of Patents w 


cm ^= 


ington,DC 20231 d cj 

P 

Transmitted herewith for filing is the Patent Application of: 
Inventor: Mark E. Peters 

For: Extension of X.509 Certificates to Simultaneously Support Multiple Cryptographic Algorithms 

Enclosed are: 

X Patent Application 

X ( 4 ) Sheets of Drawings 

X An assignment of the invention to International Business Machines, Armonk, NY 10504 
X Declaration and Power of Attorney 
Letter in accordance with Rule 1.53 


THi filing fee has been calculated as shown below: Other Than Small Entity 


F^: 

No. Filed No. Extra 

Rate 

Fee 

Basic Fee 



$ 760.00 

T$jal Claims 

3 - 20 = 0 

Ox $ 18.00= 

$ .00 

Indep. Claims 

1-3 = 

Ox $ 78.00= 

$ .00 

" Multiple Dependent Claim Presented 

$260.00 

$ .00 



TOTAL 

$ 760.00 


Deposit Account Authorization: 

„X_ Please charge Deposit Account No. 09-0461 in the amount of $760.00. A duplicate copy of this sheet is enclosed. 
_X_ The Commissioner is hereby authorized to charge payment of the following fees associated with this communication 

or credit any overpayment to Deposit Account No. 09-0461. A duplicate copy of this sheet is enclosed. 

_X_ Any additional filing fees required under 37 CF.R. §1.16. 

_X_ Any patent application processing fees under 37 C.F.R. §1.17. 

Date: January 29, 1999 

From: Gregory M. Doudnikoff 
IBM Corporation 
IPLaw, Dept. T81/Bldg. 062 
P.O. Box 12195 

Research Triangle Park, NC 27709 



Gregory M.^oudnikoff 
Attorney for Applicants 
Registration No. 32,847 


Telephone: 


919-254-1288; fax 919-254-4330 


EXTENSION OF X.509 CERTIFICATES TO 
SIMULTANEOUSLY SUPPORT MULTIPLE 
CRYPTOGRAPHIC ALGORITHMS 

BACKGROUND OF THE INVENTION 

Field of the Invention 

The present invention relates to a technique for permitting X.509 certificates to utilize more 
than a single encryption algorithm. More particularly, the present invention relates to a technique 
by which a certificate may be extended to support a second encryption algorithm while not requiring 
a new certificate hierarchy and while maintaining backward compatibility. 

Description of the Related Art 

Security for transactions and documents transmitted over networks such as the Internet have 
been a stumbling block to having true end-to-end e-commerce. Security flaws in existing systems 
are well documented, and security which is transparent to the public has been difficult to implement. 
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Thus, many people feel less than secure about sending credit card numbers and the like to merchants 
via the Internet. 

More recently, to address this problem, the companies which produce the VISA and 
MasterCard credit cards jointly came up with an end-to-end specification for securely transmitting 
credit card numbers and information as part of electronic transactions over the Internet. This 
specification, known as SET (Secure Electronic Transactions), was first introduced in 1997 (SET is 
a trademark of SET Secure Electronic Transaction LLC). 

The SET specification relies on the concept of certificates, which are issued to merchants, 
credit card holders, credit card issuers, etc. Certificates are subject to verification based on their 
'signature', and are encrypted. The standard certificate type which is used in known as the X.509 
certificate. 

One drawback to X.509 certificates is that they support only a single encryption algorithm at 
a time. Also, some encryption algorithms perform better in some environments. Recent highly 
publicized events have shown that some encryption algorithms can be broken if enough resources 
are thrown at them. This is not well received by the public. However, it has been demonstrated that 
most unscrupulous parties have only limited resources. And if the effort to decrypt a certificate 
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outweighs the potential reward, no attempt will be made to break the encryption. In this regard, SET 
certificates are somewhat vulnerable. The certificates support only a single encryption algorithm, 
and most certificates use only a single, known standard algorithm. So, while it is not easy, a party 
bent on decrypting a certificate can intercept a certificate on the Internet and have a pretty good idea 
of which algorithm is employed. By employing the extensive resources required to decrypt the 
certificate, the party can then succeed in decrypting the certificate. 

Accordingly, a need exists for making X.509 certificates support additional cryptographic 
algorithms. 

SUMMARY OF THE INVENTION 

An object of the present invention is to provide a technique for utilizing more than one 
encryption algorithm in an X.509 certificate. 

Other objects and advantages of the present invention will be set forth in part in the description 
and the drawings which follow, and, in part, will be obvious from the description or may be learned 
by practice of the invention. 
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To achieve the forgoing objects, and in accordance with the purpose of the invention as broadly 
described herein, the present invention provides an X.509 certificate capable of supporting more than 
one cryptographic algorithm, comprising a signature algorithm and signature for all 
authenticated attributes using a first cryptographic algorithm; an alternative public key extension for 
identifying at least one alternative cryptographic algorithm and providing its associated public key; 
and an alternative signature extension for containing a signature for the alternative cryptographic 
algorithm. Preferably, the first cryptographic algorithm is RSA and the alternative cryptographic 
algorithm is elliptic curve. Also, the certificate can be verified by either the signature for the first 
cryptographic algorithm or the signature for the alternative signature algorithm. 

The present invention will now be described with reference to the following drawings, in which 
like reference numbers denote the same element throughout. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 is a pictorial representation of a data processing system which may be utilized to 
implement the present invention; 
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Figure 2 is a diagram of a networked computing environment in which the present invention 
may be practiced; 

Figure 3 illustrates a certificate having extenstions in accordance with the present invention; 

and 

Figure 4 is a flow chart illustrating the logical steps involved with verifying a certificate having 
the alternative signature extensions. 

DESCRIPTION OF THE PREFERRED EMBODIMENT 

Figure 1 illustrates a representative workstation hardware environment in which the present 
invention may be practiced. The environment of Figure 1 comprises a representative single user 
computer workstation 10, such as a personal computer, including related peripheral devices. The 
workstation 10 includes a microprocessor 12 and a bus 14 employed to connect and enable 
communication between the microprocessor 12 and the components of the workstation 10 in 
accordance with known techniques. The workstation 10 typically includes a user interface adapter 
1 6, which connects the microprocessor 12 via the bus 14 to one or more interface devices, such as 
keyboard 18, mouse 20, and/or other interface devices 22, which can be any user interface device, 
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such as a touch sensitive screen, digitized entry pad, etc. The bus 14 also connects a display device 
24, such as an LCD screen or monitor, to the microprocessor 12 via a display adapter 26. The bus 
14 also connects the microprocessor 12 to memory 28 and long term storage 30 which can include 
a hard drive, tape drive, etc. 

The workstation 10 communicates via a communications channel 32 with other computers or 
networks of computers. The workstation 1 0 may be associated with such other computers in a local 
area network (LAN) or a wide area network, or the workstation 10 can be client in a client/server 
arrangement with another computer, etc. All of these configurations, as well as the appropriate 
communications hardware and software, are known in the art. 

Figure 2 illustrates a data processing network 40 in which the present invention may be 
practiced. The data processing network 40 includes a plurality of individual networks, including 
LANs 42 and 44, each of which includes a plurality of individual workstations 1 0. Alternatively, as 
those skilled in the art will appreciate, a LAN may comprise a plurality of intelligent workstations 
coupled to a host processor. 

Still referring to Figure 2, the data processing network 40 may also include multiple mainframe 
computers, such as a mainframe computer 46, which may be preferably coupled to the LAN 44 by 
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means of a communications link 48. The mainframe computer 46 may be implemented utilizing an 
Enterprise Systems Architecture/370, or an Enterprise Systems Architecture/390 computer available 
from the International Business Machines Corporation (IBM). Depending on the application, a 
midrange computer, such as an Application System/400 (also known as an AS/400) may be 
employed. "Enterprise Systems Architecture/370" is a trademark of IBM; "Enterprise Systems 
Architecture/390", "Application System/400" and "AS/400" are registered trademarks of IBM. 

The mainframe computer 46 may also be coupled to a storage device 50, which may serve as 
remote storage for the LAN 44. Similarly, the LAN 44 may be coupled to a communications link 
52 through a subsystem control unit/communication controller 54 and a communications link 56 to 
a gateway server 58. The gateway server 58 is preferably an individual computer or intelligent 
workstation which serves to link the LAN 42 to the LAN 44. 

Those skilled in the art will appreciate that the mainframe computer 46 may be located a great 
geographic distance from the LAN 44, and similarly, the LAN 44 may be located a substantial 
distance from the LAN 42. For example, the LAN 42 may be located in California, while the LAN 
44 may be located in Texas, and the mainframe computer 46 may be located in New York. 
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Software programming code which embodies the present invention is typically stored in 
permanent storage of some type, such as the permanent storage 30 of the workstation 10. In a 
client/server environment, such software programming code may be stored with storage associated 
with a server. The software programming code may be embodied on any of a variety of known 
media for use with a data processing system, such as a diskette, or hard drive, or CD-ROM. The 
code may be distributed on such media, or may be distributed to users from the memory or storage 
of one computer system over a network of some type to other computer systems for use by users of 
such other systems. The techniques and methods for embodying software program code on physical 
media and/or distributing software code via networks are well known and will not be further 
discussed herein. 

The preferred embodiment of the present invention will now be discussed with reference to 
Figures 3 through 4. 

The architecture and features of X.509 certificates are well known and will not be described 
in detail herein. Basically, the current SET specification utilized RSA public key cryptography as 
the encryption technique for the X.509 certificates it has defined for use therewith. And standard 
X.509 only supports having one public key being certified in a certificate. Likewise, a certificate 
issuer can only sign with one key type. In this scenario, only one algorithm can be supported. If 
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support is desired for a second algorithm, a distinct certificate hierarchy would be required. 
Maintaining a second hierarchy would be very expensive. 

Further, if the current X.509 public key and signature elements were to be changed from a 
single item to a multiple item format, the new certificates would be incompatible with the old ones. 

All extensions in an X.509 certificate are included in the portion of the X.509 certificate 
referred to as "data to be signed". Elements in the "data to be signed" portion are not encrypted; thus 
they may be obtained for validation and are protected from modification by the signature. 

Referring now to Figure 3, an outline 70 of an extended X.509 certificate according to the 
present invention is illustrated. The present invention provides two new X.509 extensions 72, 74. 
The first extension 72 lists the alternate algorithms with the associated public key being certified for 
that algorithm. The second extension 74 lists alternative signatures for algorithms supported by the 
issuing certificate authority. When validating the primary or existing signature in a signed X.509 
certificate, the certificate is signed over the entire unsigned certificate, including all extensions. 
When validating the signature of an alternate signature, the signature is validated for the unsigned 
certificate, except for the extension containing the list of signatures. This allows the important 
information to be authenticated with any of the signatures, and allows backward compatibility with 
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entities which understand single algorithm certificates only (as long as the primary signature is with 
the supported algorithm). 

Preferably, the alternate signatures extension will be a list of items, with each item containing 
the signature item algorithm (including key type) and the signature. The public keys of the entity 
being certified are contained in a list where each item contains the key algorithm type and the key. 

To sign the certificates, the certificate authority will start by signing with the alternate 
algorithm. First, the certificate authority signs the unsigned certificate without the alternate signature 
extension using all of the desired certificate authority's alternative signature private keys. 

Each of the corresponding certificate authority alternative signature public keys must be present 
in the Certificate authority's issuing certificate in its own alternate signature extension. Each 
signature is added to the alternate signatures extension. Finally, the entire unsigned certificate 
(including the alternate signatures extension) is signed using the certificate authority's private key 
that corresponds to the public key contained in the existing signature portion of the certificate 
authority's X.509 certificate. Thus, any 'old' entity should be able to use the previous public key 
cryptographic algorithm in the certificate hierarchy with no modifications. 
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Using this technique, an first entity which supports only one algorithm, such as RSA 
cryptography, can validate a message (containing a certificate) from a second entity which supports 
both RSA and a second algorithm, such as elliptic curve, in its extension. (The certificate authority 
that signed the second entity's certificate would also support both algorithms.) The first entity 
would, upon reviewing the certificate from the second entity, find that the certificate contains an RSA 
public key that is signed by a certificate authority that the first entity trusts. The first entity wold also 
notice that there is an extension that the first entity does not understand, but that extension is 
considered non-critical, and can be ignored without repercussion. 

A third entity which only supports elliptic curve may also validate a message from the second 
entity. The third entity would review the certificate from the second entity and understand that the 
primary algorithm is RSA and that the certificate is signed with RSA. The third entity would review 
the extensions and determine that the certificate also has an elliptic curve public key and an extension 
that contains an elliptic curve alternative signature. If the third entity validates the alternative 
signature and the third entity trusts the issuing certificate authority, the third entity can trust that the 
elliptic curve key in the certificate is legitimate. 

Since the extension is marked as non-critical, entities that do not support the multiple algorithm 
enhancement could continue to function under the original public key algorithm, without needing to 
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be aware of or modified for the extension. Also, when new root certificates are issued for a protocol 
or implementation, the new root can add the extensions and the root trust mechanisms (via key or 
certificate hashes) do not have to be changed. For example, future SET roots can add elliptic curve 
support by adding these extensions and both the SubjectPublicKeylnfo hash validation and the root 
horizontal chaining continue to work exactly as before. 

Figure 4 is a flowchart which illustrates the logic associated with verifying an extended X.509 
certificate according to the present invention. First, a receiving entity receives a certificate (Step 
1 00). Then, a determination is made as to whether the verification algorithm for the receiving entity 
is for the outer algorithm, i.e., the signature algorithm for the authenticated attributes (Step 102). If 
this is determined to be the case, processing of the extension algorithm does not have to occur. 
Verification and authentication of the certificate is then carried out in accordance with the existing 
single algorithm technique (Step 102). 

If it is determined in Step 102 that the primary signature is not supported by the receiving 
entity, the alternative signature in the extension is checked for a match (Step 106). If no match 
occurs here, processing ends, as the certificate cannot be verified. If a match does occur, processing 
proceeds to Step 108, in which the alternative signature extension is removed from the attributes. 
The attributes are then re-encoded in accordance with known techniques, and hashed. Verification 
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of the alternative signatures is then performed in accordance with known techniques. Processing then 
ends. 

Although the present invention has been described with respect to a specific preferred 
embodiment thereof, various changes and modifications may be suggested to one skilled in the art 
and it is intended that the present invention encompass such changes and modifications as fall within 
the scope of the appended claims. 


CR9-98-095 


13 


CLAIMS 


1 . An X.509 certificate capable of supporting more than one cryptographic algorithm, comprising: 

a signature algorithm and signature for all authenticated attributes using a first cryptographic 
algorithm; 

an alternative public key extension for identifying at least one alternative cryptographic 
algorithm and providing its associated public key; and 

an alternative signature extension for containing a signature for the alternative cryptographic 
algorithm. 

2. An X.509 certificate according to Claim 1, wherein the first cryptographic algorithm is RSA 
and the alternative cryptographic algorithm is elliptic curve. 

3 . An X. 5 09 certificate according to Claim 1 , wherein the certificate can be verified by either the 
signature for the first cryptographic algorithm or the signature for the alternative signature algorithm. 
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Abstract 


EXTENSION OF X.509 CERTIFICATES TO 
SIMULTANEOUSLY SUPPORT MULTIPLE 
CRYPTOGRAPHIC ALGORITHMS 


A technique permitting an X.509 certificate to simultaneously support more than one 
cryptographic algorithm. An alterative public key and alternative signature are provided as 
extensions in the body of the certificate. These extensions define a second (or more) cryptographic 
algorithm which may be utilized to verify the certificate. These are not authenticated by the primary 
signature and signature algorithm in the primary cryptographic algorithm. These newly defined 
extensions are reviewed by a receiving entity if the entity does not support the cryptographic 
algorithm of the primary signature. 
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X.509 Certificate 


Authenticated Attributes 

Issuer Name 
Subject Name 
Serial Number 
Public Key 
Extensions 


Authority Key Identifier 



Mark E. Peters 
CR9-98-095 
4/4 


c 


)66 


SAjtof to 



N 


112 


fa-K,^ llfflfnafM 


?e.r$<jr*- Vindication 


CR9-98-095 


Declaration and Power of Attorney for 
Patent Application 


As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my name; I believe I am the 
original, first and sole inventor (if only one name is listed below) or an original, first and joint inventor (if plural 
names are listed below) of the subject matter which is claimed and for which a patent is sought on the 
invention entitled 

Extension of X.509 Certificates to Simultaneously Support Multiple Cryptographic Algorithms 

the specification of which (check one) 


I hereby state that I have reviewed and understand the contents of the above- identified specification, 
including the claims, as amended by any amendment referred to above. 

I acknowledge the duty to disclose information which is material to the patentability of this application in 
accordance with Title 37, Code of Federal Regulations, §1 .56. 

I hereby claim foreign priority benefits under Title 35, United States Code, §1 19 of any foreign application(s) 
for patent or inventor's certificate listed below and have also identified below any foreign application for patent 
or inventor's certificate having a filing date before that of the application on which priority is claimed: 

Prior Foreign Application(s): 

Number Country Day/Month/Year Priority Claimed 

I hereby claim the benefit under Title 35, United States Code, §120 of any United States application(s) listed 
below and, insofar as the subject matter of each of the claims of this application is not disclosed in the prior 
United States application in the manner provided by the first paragraph of Title 35, United States Code, §112, 
I acknowledge the duty to disclose information material to the patentability of this application as defined in Title 
37, Code of Federal Regulations, §1 .56 which occurred between the filing date of the prior application and the 
national or PCT international filing date of this application: 

Prior U.S. Applications: 

Serial No. Filing Date Status 


I hereby declare that all statements made herein of my own knowledge are true and that all statements made 
on information and belief are believed to be true; and further that these statements were made with the 
knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, 
under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize 
the validity of the application or any patent issued thereon. 
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A.B. Clay, Reg. No. 32,121; G. M. Doudnikoff, Reg. No. 32,847; E. H. Duffield, Reg. No. 25,970; J. W. 
Herndon, Reg. No. 27,901; J. S. Ray-Yarletts, Reg. No. 39,808; 
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